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A DATABASE DRIVEN WORKFLOW MANAGEMENT SYSTEM FOR 
GENERATING OUTPUT MATERIAL BASED ON CUSTOMER INPUT 

Inventors : Leonard C. Lahey, Robert C. Nielsen, Jagdish M. Nagda, Dwight R. 
5 Palmer, Adam A. Swartz, and Anthony F. Stuart. 

BACKGROUND OF THE INVENTION 

1. Field of the Invention 

The present invention relates to method, system, and program for a database 
1 0 driven workflow management system for the automated creation and delivery of 
customer output and, in particular, output material based on customer input. 

2. Description of the Related Art 



1 5 marketing materials tailored for different customers. Many systems have a database 
of customer information and merge the customer information from the database into 
customer marketing material forms that are then mailed or otherwise distributed to the 
customer. Typically, the marketing material forms have variable fields into which the 
customer information is inserted from the database during the process of merging the 

20 forms with the database data. 

The effectiveness of a direct mail marketing campaign can be significantly 
improved by customizing the content of marketing materials to each customer's needs 
and situation. Existing and potential customers will more likely pay attention to 
marketing materials that appear to directly address issues that are pertinent to the 

25 customer. Likewise, customers will tend to ignore marketing materials that include 
information that is irrelevant to the their needs and preferences. Thus, computerized 
direct mail marketing methods continually seek to provide ways to further customize 
direct mail marketing materials to the specific needs and desires of customers. 



Direct mail printers and printer software allow a user to generate and print 
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One current problem with customized mail marketing is that substantial 
human intervention is needed to gather the customer information and prepare the 
generated customized marketing material for distribution. After the files are 
generated they are typically printed, then placed in an envelope. There can often be a 
5 considerable lag time between the time customer information is gathered and the 
customized materials are generated, then mailed to the customer. 

Delivery of non-customized marketing material can occur instantly, and is 
sometimes transmitted via facsimile or electronic mail. However, for the reasons 
discussed above, non-customized marketing material is not as effective a marketing 
1 0 tool as customized information. 

Accordingly, there is a need in the art for an improved system, method, and 
program for generating and delivering tailored marketing materials to existing and 
potential customers. 



To overcome the limitations in the prior art described above, preferred 
embodiments disclose a workflow management system for creating and delivering 
output material, A customer record is generated to include fields specifying at least 
one product, customer preferences, and a selected output method to deliver generated 

20 output material on the product specified in the customer record, A job record 
including a status field is added to a job status table for the customer record. The 
added job record status is set to a first status. A selected job is processed in the job 
status table. A first worker is invoked if the selected job has the first status. The first 
worker generates ou^ut material fi*om processing the product and customer 

25 preference fields in the customer record for the selected job. The status for the 

selected job in the job status table is set to a second status after generating the output 
material. A second worker is invoked if the selected job has the second status. The 
second worker determines a selected one of a plurality of delivery options fi:om the 



SUMMARY OF THE PREFERRED EMBODIMENTS 
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customer record for the selected job and transmits the output material via the 
determined delivery option to the customer specified in the customer record. 

In further embodiments, the first status is associated with the first worker and 
the second status is associated with the second worker. The first and second workers 
5 fijrther query the job status table to access all jobs having the status associated with 
the worker. 

In still further embodiments, the job status table is processed by a supervisor 
program that polls the job status table at predetermined intervals. In such case, the 
supervisor program performs the steps of invoking the first and second workers and 

10 setting the status to the second status. The supervisor program processes every record 
in the job status table when performing the polling operation. 

Preferred embodiments provide a database driven workflow management 
system for creating and dehvering output material and, especially, direct marketing 
material A job enters the workflow system by adding a record to a job status table 

15 for a generated customer record and setting the status to a first status. The customer 
record is used to determine the output to generate onto a template, which when 
generated includes the tailored marketing information to send to the customer. A 
worker invoked in response to the first status processes the customer record to 
generate the output material. Other workers are also used to post-process the output, 

20 generate the output and then automatically transfer the processed output material to 
the customer via different possible transmission routes specified in the customer 
record. 

The database driven workflow system is defined by associating each worker 
with an input status. The ordering of worker processes is defined by setting the status 
25 of the job to the input status of the next worker in the workflow process as indicated 
in the database after processing the job. In this way, a change in the workflow as 
defined by the input and output statuses changes the workflow environment to 
provide a just-in-time type system for processing jobs using database technology. 
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This system automatically routes a print job through various states to generate and 
deliver output material without the need of human intervention. 

BRIEF DESCRIPTION OF THE DRAWINGS 
5 Referring now to the drawings in which like reference numbers represent 

corresponding parts throughout: 

FIG. 1 is a block diagram illustrating a computing environment in which 
preferred embodiments of the present invention are implemented; 

FIGs. 2a and 2b illustrate an entry form to enter a customer record in 
1 0 accordance with preferred embodiments of the present invention; 

FIG. 3 illustrates an example of marketing material generated in accordance 
with preferred embodiments of the present invention; 

FIG. 4 illustrates an example of a layout of a template used to generated 
tailored marketing material in accordance with preferred embodiments of the present 
15 invention; 

FIGs. 5a and 5b illustrate logic to generate marketing material in accordance 
with preferred embodiments of the present invention; 

FIG. 6 illustrates an example of components of the workflow management 
system in accordance with preferred embodiments of the present invention; 
20 FIG. 7 illustrates a workflow transition table in accordance with preferred 

embodiments of the present invention; 

FIG. 8 illustrates a job status table used with preferred embodiments of the 
present invention; 

FIG. 9 is an example of the workflow in accordance with preferred 
25 embodiments of the present invention; 

FIG. 10 illustrates logic to process a job status table to route a print job 
through the workflow system in accordance with preferred embodiments of the 
present invention; and 
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FIG. 1 1 illustrates worker logic to process a print job in accordance with 
preferred embodiments of the present invention. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 
5 In the following description, reference is made to the accompanying drawings 

which fomi a part hereof and which illustrate several embodiments of the present 
invention. It is understood that other embodiments may be utilized and structural and 
operational changes may be made without departing from the scope of the present 
invention. 

10 

Computing Environment 
FIG. 1 illustrates a network environment 2 in which preferred embodiments 
are implemented. One or more data input centers 4 are used to gather information on 
existing and potential customers and store the information in customer records in a 

15 customer database 6, A content database 8 is comprised of files that include content 
to insert into a template describing a layout of the marketing materials (discussed 
below). The content of the files in the content database 8 may comprise any image 
and text type knovm in the art, including three dimensional images, holographic 
images, watermark, etc. Further, if the marketing pages are to be viewed in a Java 

20 enabled or other multi-media viewer, then the file may include video images, sound 
files, three dimensional images, and any other multi-media format known in the art. 

An output constructor 10 receives the template and using information in a 
customer record from the customer database 6 and the content database 8 populates 
the template with marketing information tailored for the customer. After generating 

25 direct marketing material comprised of the populated template in accordance with 
preferred embodiments described below, the output constructor 10 may then direct the 
marketing material to a printer 12 for printing or to a facsimile (fax) machine 14 for 
facsimile transmission to the targeted customer. Further, the marketing materials may 
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be converted into a portable format, such as an Hypertext Mark-Up Language 
(HTML) or XML page or in the an ADOBE ACROBAT** format to transmit to the 
customer via e-mail 16. A network 12 provides conamunication among the data input 
computer 4, customer database 6, content database 8, output constructor 10, printer 
5 14, fax machine 16, an e-mail gateway 18 to customers, and a workflow engine 20. 
The network 1 8 may be comprised of any network system known in the art including 
TCP/IP network (e.g., an Intranet, the Intemet), LAN, Ethernet, WAN, Token Ring, 
etc. Alternatively, there may be separate and different networks between the 
components. 

1 0 The data input computer 4 and output constructor 1 0 would include an 

operating system such as MICROSOFT WINDOWS 98, WINDOWS NT, AIX, 
OS/390, OS/2, MVS,** and may be comprised of any suitable server and client 
architecture known in the art. The output constructor 1 0 would include software 
suited for processing multiple large print jobs, such as the IBM InfoPrint manager 

1 5 software that runs on the IBM RS/6000 server under the AIX operating system.** 

The customer 6 and content 8 databases maybe located on the same database 
server or on separate database servers. The data input computer 4 and output 
constructor 10 would include cUent database software to communicate with the 
server(s) including the customer 6 and content 8 databases. The client/server database 

20 software to implement the customer 6 and client 8 databases in the network 2 may be 
comprised of any chent/server database program known in the art, such as IBM DB2, 
Oracle Corporation's ORACLE 8,** etc. The client/server database software would 
allow the data input computer 4 and output constructor 10 to transfer data, execute 
SQL queries, and update data with respect to the customer 6 and content 8 databases 

25 in a manner known in the art. 

The printer 14 may be any large scale printer capable of mass printing 
marketing materials, such as the IBM InfoColor 70. The facsimile machine 14 is 
preferably capable of handling multiple facsimile transmissions at a time to batch 
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process facsimile jobs. For instance, the output constructor 10 may immediately 
transmit generated output or, alternatively, save generated output for later batch 
processing of the transmission operations. Details of the InfoPrint manager and 
printing documents to alternative output devices such as e-mail and fax machines is 
5 described in the IBM publication, "IBM InfoPrint Manager for AIX: Administrators 
Guide Version 3, Release 1," IBM Document No, S544-5595-00 (October 1998), 
which publication is incorporated herein by reference. 

The database driven workflow engine 20, described below, controls the 
scheduling of the processing of the job and manages the entire job flow from data 
10 input, through formatting to the output 14, 16, and 18. 

Gathering Customer Information 
In preferred embodiments, detailed information about a customer may be 
gathered by an operator at a marketing call center. The operator at the marketing call 

1 5 center speaks with a representative of the customer and enters information at the data 
input computer 4 into a customer database record for that customer. The operator 
would enter the data into a database entry form. FIGs. 2a and 2b provide an example 
of a customer record database entry form, showing two different scrolled areas of the 
same page, including customer information fields. With respect to FIG. 2a, the 

20 customer contact field could include information on the contact person of the 

customer. Further fields may be provided for the address, title, mail-stop, etc., of the 
contact. The customer name and location fields may include further sub-fields for the 
address components of the customer location. The industry type field indicates the 
industry in which the customer operates and the customer boolean field indicate 

25 whether the customer is a business or technical entity. For instance, this may indicate 
whether the contact has specific technical knowledge and understanding of the 
equipment or is focused on less technical, business operations. 
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FIG. 2b shows further fields in the customer record, including the type of 
printing of interest to the customer; concerns the customer has about the printer 
product (customer's current issue with printers); associated services of interest. This 
page also allows the operator to enter information on the services and features of 
5 interest to the customer. Below is a drop down hst to allow the operator to select a 
desired delivery method for the customer. Upon selecting a delivery method, the 
program would prompt the user to enter customer address information for the delivery 
method, e.g., e-mail address, fax number, street address, etc. 

Each of the fields included in the customer record entry form illustrated in 

1 0 FIGs. 2a and 2b generates information into fields or columns of a database record for 
the customer. The customer database would include a column for each field of 
information provided in the form. A customer record is created each time the 
operator fills in information for a product of interest to the customer. Thus, if the 
customer is interested in different products, then different customer records would be 

1 5 generated, one for each product. The customer records are stored in a table in the 
customer database 6. 

Alternatively, information to enter into the customer record fields (columns) 
may be mined from a database of information on the customer. This database is 
mined to gather information that can then be inserted into customer records, 

20 The arrangement and selection of fields to include in customer records would 

be determined during the design of the layout of the template. A template would be 
designed to include information on the product, A template is comprised of 
containers, which are sections into which files from the content database 8 are 
inserted. Each of the files in the content database 8 include metadata in the form of a 

25 database record in the content database 8 that provides attributes associated with the 
file. The metadata would include fields or columns of information that corresponds 
to the fields in the customer record. Thus, the meta data for a particular file could 
indicate whether the information is for a business or technical oriented contact, 
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corresponding to the business or technical selection in the customer record and a size 
of the company, along with other indicators of preferences addressed by the file. For 
instance, a file could include information tailored to a non-technical person at a large 
company. The needs of a large company are quite distinct from that of a small 
5 company. Thus, the files inserted into the container may be customized depending on 
both the background of the contact and size of the company. In this way, there is a 
correspondence of fields (columns) in the customer records in the customer database 
6 and fields (columns) the metadata records for each file in the content database 8. 
A search engine would query the metadata record of a file using data entered 

10 in the fields of a customer record, such that a file is selected having metadata 

attributes matching attributes associated with the customer in the customer record. 
The query may query the metadata records on multiple attributes from the customer 
record, e.g., contact background (e.g., technical or business), size of company, and 
some other customer preference. 

1 5 The template bridges files in the content database 8 and the customer records 

in the customer database 6 to generate tailored marketing material. In this way there 
are two levels of customization, one based on generating information directly from 
the customer record to the template and the second is based on using the preferences 
and information in the customer record to query and select a file that includes content 

20 tailored to the customer expressed preferences based on multiple degrees of 

customization, e.g., size, contact background, and any other preferences. Thus, a file 
to insert into a container may be queried on multiple customizing variables, i.e., 
multiple customer specific attributes entered in the customer record in the customer 
database 6. With this multi-level customization, a customized file may be selected to 

25 generate customize information in a container and the customized information may 
include external references to data in the customer record to provide a second layer of 
customization to the container. 
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FIG, 3 illustrates an example of a marketing brochure produced in accordance 
with the preferred embodiments. A designer would design the layout of a template 
including containers, which are regions of the template into which content from files 
from the content database 8 are inserted. FIG. 4 illustrates a template 100 in which 

5 the user defines the layout of how content in the files in the customer 6 and content 
databases 8 will be inserted into the template 100 to generate the marketing material. 
The designer creates containers within the template 100. A product name container 
102 displays the name of the product of interest to the customer. This information is 
accessed directly from the Product field (shown in FIG. 2a) of the customer record 

1 0 and displays the product name, numbered as 50 in FIG. 3 . 

An introduction container 104 includes a reference to an introductory file. As 
shown in container 104, the introductory file includes static text and references to 
variable data in the customer record. The introductory container 104 may also 
include a query of introduction files based on contact background (technical or 

15 business) and the size of the company. This would select an introduction file 
including information tailored to the contact background and company size. The 
introduction container 104 fiirther includes the abiUty to insert variable customer 
information from the customer record directly into the introduction text to tailor the 
introduction to the customer, the contact background, and the company size. 

20 A first paragraph container 106 includes the first paragraph following the 

introduction. To access files from the content database 8 to insert into a container, the 
designer would insert an SQL query into the container 106 to query the metadata 
records in the content database 8 to find a file that matches the queried value from the 
customer record. The content database 8 is set-up such that there are numerous files 

25 created for each container. The metadata of each file associates each file with one of 
the containers. The metadata further includes values in one or more columns (fields) 
that correspond to fields in the customer record including operator entered customer 
preferences. For instance, there may be numerous files dedicated to paragraph 1 , 
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each having in the associated services column one of the possible values for this 
column that could be entered for the customer. Further each file for paragraph 1 may 
have further degrees of customization upon the contact background and company size. 
The container 106 includes an SQL query to query the "associated services" column 
5 in the metadata record for a value that matches the value for this same column in the 
customer record. Thus, the container 106 includes the type of query, i.e., columns 
that will be queried, and the search criteria for the query is determined dynamically 
from the customer record. FIG. 3 shows an example of the paragraph 1 inserted, 
numbered as 54, when Environment Sharing was entered as an associated service to 

1 0 include for the customer. 

Similarly, container 108 includes a query on the type of printing. This 
searches the files for paragraph 2 that have a "type of printing" column value that 
matches the type of printing in the selected customer record. In the example, the 
customer record, in FIG. 2a, shows the "type of printing" as continuous forms. This 

1 5 would cause the selection of a file including in its associated metadata indication that 
it is a paragraph 2 file and that has a value of "continuous forms" in the "type of 
printing" column . As shown in FIG. 3, the "continuous forms" value causes the 
insertion in the paragraph 2 container 108 of a file including information on media 
flexibility, numbered 56 in FIG. 3, which describes the type of forms and data that 

20 may be driven through the system. 

The above description highlights how a designer would design the template 
1 00, format of the customer records (FIGs. 2a, b), and the files and metadata to 
include in the content database. First the designer would determine the containers to 
include in the template and then the type of content to include in each container that 

25 would interest the customers. The designer would then determine a way to describe 
different attributes values for the ways in which the interest could be classified. The 
customer record entry form would be designed to allow an operator to select one of 
multiple attribute values for the interest. Further, the files to fill in the container 
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associated with the customer interests and demands would include a field indicating 
the container with which it is associated and each file would include in the field 
corresponding to the interest one of the attribute values for the interest. In this way, 
each file would include information tailored to the possible attribute and interest 
5 values in the customer record. For instance, the value for the "type of printing" 
attribute would determine the selection of a file, for container 108, having a value in 
the "type of printing" attribute field equal to the value entered for this field in the 
customer record. In this way, each file in the content database 8 associated with a 
container has an attribute value in a field (column) corresponding to an attribute value 

10 in a field (column) in the customer record. The container would include a query to 
search the metadata of the files associated with the container for a file that has an 
attribute value matching the attribute value in the column. 

For example, container 110 indicates a "customer type" field, which 
corresponds to the selection in the customer record entry form of "business" or 

15 "technical" A query of this field for business would include a section description 
more usefiil for business, non-technical types, such as a general description of 
fimctions; whereas a technical value would refer to the file including a technical 
description. The layout 100 also includes containers 1 12a, b, c, d to generate the 
display of product highlights, shown as numbers 60, 62, and 64 in FIG. 3. One or 

20 more highlights are filled into the containers 1 12a, b, c, d from files in the content 
database 8 Each highlight container 1 12a, b, c, d includes a query of the metadata in 
the content database 8 to retrieve the file for the highlights having a column value 
matching the search value in the corresponding column in the customer record. For 
instance, the "type of printing field," indicates the type of printing the customer is 

25 interested, which is shown as "Continuous forms" in FIG. 2b. The container 1 12a 
would insert highlights relating to the type of printing from a file having a "type of 
printing" metadata field value matching that for the customer record. The "type of 
printing" highlights are shown as highlights 60 in FIG. 3. For the second container 
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1 12b, the query on the"associated services" field (column) would search for the value 
for this field in the customer record, which is "Distributed print services." This 
accesses the file having the same value in the "associated services column," which 
displays the "Environment Sharing" paragraph shown as the highlight numbered 62 
5 in FIG. 3. The third container 1 12c provides static highlights which are generated 
directly fi-om the container, without access fi:om either database 6 or 8, fixed and not 
variable information. These static highlights are features for the product to always 
include in the marketing material, and shown as number 64 in FIG. 3. The last 
highUght container 1 12d retrieves the file having a "customer issues" value matching 

1 0 that of the customer record. 

FIGs. 5a, b illustrate logic implemented in the output constructor 10 to process 
a template 50, the customer database 6, and the content 8 databases to generate 
marketing output. Control begins (at block 200) with the output constructor 10 
receiving a customer record firom the customer database 6 and retrieving a template. 

15 The output constructor 10 may receive templates and records during a batch 
processing mode to generate marketing materials from a template for multiple 
customer records. Alternatively, the output constructor 10 may selectively process 
customer records to generate the output material. The output constructor 10 then 
begins a loop at block 202 for each container i in the template. Within the loop, the 

20 printer manager first determines (at block 204) whether the content in the container is 
static, i.e., no variables referencing data in the customer database 6 or the content 
database 8. If so, the output constructor 10 generates (at block 206) the static text 
from the container into the output and proceeds (at block 208, in FIG. 5b) to process 
the next container by returning to block 202. If the content is not static, then the 

25 output constructor 1 0 determines (at block 210) whether a query is included. If not, 
then the reference must be to a field in the customer record and the data from the 
customer record for the column (field) identified in the container is accessed (at block 
212) from the data in the customer record. The output constructor then generates (at 
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block 214) the text from the container into the output with the variable data from the 
customer record at the location where the variable was placed. For instance, in 
container 104 in FIG. 4, there are references to variables corresponding to fields in the 
customer record to insert in the text to conform the introductory paragraph 104 to the 
5 preferences for the customer entered in the customer record. As shown in number 52 
in the output in FIG. 3, the introduction paragraph mentions specific key concems and 
preferences for the customer. After generating the text into the container, control 
proceeds (at block 208) back to block 202 to process the next container. 

If a query is included in the container, then the output constructor accesses (at 

1 0 block 2 1 6) the data in the customer data record column corresponding to the column 
subject to the query. The output constructor then builds and submits a query (at 
block 218) to query metadata records in the content database 8 for records for the 
container i and satisfying the search criteria and value from the customer record. If 
there is a matching metadata record (at block 220, in FIG. 5b), then the output 

15 constructor 10 accesses the file associated with the metadata record and generates (at 
block 226) the content of the accessed file into the output. If (at block 220), there was 
no matching data record, then the output constructor 10 would access default content 
for the container. After generating the content, control returns to block 202 to 
consider the next container until all containers have been considered. After 

20 generating the final output, the output constructor 10 determines the output device, 
from the customer record, and then sends the generated output to the output device to 
send to the customer. 

The selected output device indicated in the customer record may determine 
how the output is generated. For instance, if the marketing output will be transferred 

25 by e-mail 1 8, then the document may be transformed into an Adobe Acrobat format, 
or other portable document format, for transmittal for the e-mail system. For the fax 
14 and the printer 14, the output would be similarly tailored to those or any other 
output devices. The generated output is then converted (at block 230) into a format 
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compatible with the output device. For instance, if the output device is the fax 14, 
then the output would be converted into the CCIT Group 3 fax format, and if the 
output device is the e-mail gateway 18, then the output is converted into the Adobe 
Acrobat PDF format for attachment to an e-mail message to the customer. 

The output constructor then builds (at block 232) delivery parameters for the 
converted output. The delivery parameters would comprise other components to 
include with the converted output when transmitting through the output device. For 
instance, for the fax 14, the delivery parameters could define a fax cover page to 
include with the marketing materials. The output constructor 10 would insert data 
into the fax cover page from the customer record, e.g., the customer's fax, contact 
person, etc. For e-mail, the delivery parameters would comprise the e-mail message 
including customer information in the address fields obtained fi-om the customer 
record. The output constructor 10 would then transmit (at block 234) the converted 
output material along with any delivery parameters to the customer via the appropriate 
output device, e.g., printer 12, fax 14, e-mail. 18. 

Further, the customer database 6 may include status records, fields or tables 
associated with customer records indicating the status of generation and transmission 
of output material for an associated customer record, e.g., whether output material 
was generated for a customer, transmitted, successfiiUy transmitted, failed, etc. In 
this way, the customer database 6 serves as the status focal point of the system. An 
administrator could also query the status records to determine the status of generating 
and transmitting output material for a given customer record. Further embodiments 
would include error handling mechanisms if the transmission of the output material 
via the fax 14 or e-mail gateway 18 fails. The system could automatically query the 
status records for failed transmissions, and then redrive the transmissions or 
automatically notify an administrator to take corrective action, such as check whether 
the customer contact and address information is correct. 
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Preferred embodiments utilize software to format the generated output to align 
properly in the columns of the marketing material. The template 50 and containers 
therein may be generated using page layout software known in the art, such as the 
PAGEFLEX** software, which provides tools for a user to design a layout of 
5 containers into which data fi-om a database is generated. This software fiirther 
expands or shrinks the size of the containers based on the amount of data generated 
therein, such that each container maintains its relationship as defined in the layout in 
the output. With this software, text in a container may also be wrapped around any 
image inserted into the container. Further details of the Pageflex software is 
1 0 described in the publication "Pageflex Server Setup and Reference Guide Version 
1.5.1" (Copyright Bitstream Inc., 1998-99), which publication is incorporated herein 
by reference in its entirety. 

Preferred embodiments provide a system, method, and program to tailor 
marketing material to include information that is relevant to the customer's needs and 

1 5 interests. Further, by using the same layout design across products all the marketing 
material from the customer has the same look-and-feel. Thus, to the extent the 
company has a design that is particularly effective in conveying marketing 
information and associates the company with the material, this design and layout can 
be utilized for all products and to present the tailored information to the customer. 

20 Preferred embodiments provide a system for associating customer interests and 
demands with particular files that include pertinent information specific to the 
customer's interests and demands to generate into the output for that customer. In this 
way, different customers may receive different information in their marketing 
materials, dependent upon customer interests and demands entered into the customer 

25 records. 

In preferred embodiments, numerous print requests are batched for different 
customer records. The batch job is then sent to the output constructor 10 to generate 
output for the output device 14, 16, and 18 indicated in the record. The formatted 
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template into which all the file contents are generated is then use to create a full color 
PostScript file along with the delivery output information specified in the customer 
record. The output constructor 10 then transforms the output PostScript files to a 
format that is compatible with the customer specified output device 14, 16, and 18, 
5 such as an Adobe Acrobat PDF file for e-mail or a fax format, such as CCITT Group 
3, known in the art. A delivery routine implemented within the output constructor 
10 then takes the delivery formatted output file and manages the printing, e-mailing 
and faxing of the output If e-mail or fax is selected as the preferred output method, a 
hard copy of the PostScript file is printed and mailed to the customer. 

1 0 Thus, preferred embodiments provide an integrated automated creation and 

dehvery system for gathering customer data, submitting customer data, and then 
printing in an automated manner. Once the customer specific information is entered 
into a customer record, then the entire printing processes can generate tailored 
marketing materials and automatically print or otherwise distribute the output based 

15 on a customer preferred output system. 

Using a Database Driven Workflow Manager to 
Control the Production Process 
In preferred embodiments, a customer record is processed according to a 
20 database driven workflow management system. After a customer record is created at 
the data input computer 4, then information on the customer record is added to a job 
status table. FIG. 6 illustrates components of the database driven workflow 
management system in a production system. The database driven workflow 
management system utilizes a database 252 including a job status table 254 (such as 
25 the job status table 254 shown in FIG. 6), a workflow transition table 256, worker 
specific tables 258, a customer input table 260, and a job status history table 262. 
Preferred embodiments utilize the workflow management system described in the 
copending and commonly assigned patent application entitied "Applying Relational 
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Database Technology to Process Control in Manufacturing Processes," having U.S. 
Serial No. 09/327,372 and filed on June 4, 1999, which patent application is 
incorporated herein by reference in its entirety. After a customer record is created 
through customer user input 250, or from mining corporate databases, the customer 
5 database record is added to the customer input table 260. 

A supervisor workflow manager 304 process polls the customer input table 
260 and the job status table 254. Upon locating a new customer record in the 
customer input table 260, the workflow manager 304 would create a record in the job 
status table 254 for the new customer record and set the status for that job to ready. 
10 This begins the workflow process to create a job for the new customer input record in 
the customer input table 260. Each worker comprises a self-contained application 
program that performs a specific piece of work on a print job in the direct mail 
processing system. Each worker 312, 314, 318, 320, 322, 324, 326, and 328 is 
associated with one input status and one or more output statuses depending on the 
1 5 completion status of the j ob when the worker is completed precessing the j ob. 

The workflow transition table 256 includes the input and output statuses for 
each worker. When a worker completes 312, 314, 318, 320, 322, 324, 326, or 328 its 
processing of the job, either the worker, the supervisor 304 or some other application 
would determine the appropriate output status for that worker from the workflow 
20 transition table 256 and then set the new status for the job to that determined output 
status. In this way, an administrator can readily modify the workflow by only 
updating data in just the workflow transition table 256. Further, in preferred 
embodiments, the workers do not interact directly, except through altering settings in 
the workflow transition table 256. 
25 The workflow transition table 256 may indicate for each worker different 

outputs for different outcomes. If the outcome is an error, then the output status may 
be an error state. If the outcome is successful, then the output status would be the 
input status of the next worker in the workflow process. 
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FIG. 7 illustrates an example of a workflow transition table 330 including a 
workflow having the name "2-up Print". Thus the workflow transition table 330 may 
include multiple workflows identified by the "Workflow Name" field. The "From 
Worker" indicates the input worker and the "From State" indicates a possible state 
that may occur after the "From Worker" completes processing the job. For instance, 
the "From Worker" Getlnput ends a job with one of two possible states, "complete" or 
"error." The "From Worker" Condition completes a job in one of three states, 
"complete," "NeedGraphs" or "error". The "To Worker" indicates the output worker 
that the supervisor 308 invokes upon receiving a message that the "From Worker" 
ended a job in the "From State". The "To State" indicates the output state the 
supervisor 308 sets for the job when a job is completed by the worker indicated in the 
"From Worker" field with the result indicated in the "From State." 

In preferred embodiments, the worker completing a job (From Worker) would 
update the status in the job status table 252 to the "From State" indicating the 
outcome of processing the job, e.g., complete or error and set a flag indicating that the 
record was updated. The supervisor 308 would then poll the job status table. FIG. 8 
illustrates an example of a job status table 252 that includes a job ID, current status, 
current worker, workflow name, status time stamp, priority, and update flag. The 
current status indicates a current status and the current worker indicates the worker 
currently processing the job. The workflow name column indicates the name of the 
workflow processing the job, the priority column indicates a priority of the job, and 
the update flag indicates when a record is updated by one worker or the supervisor 
308. 

When a worker completes processing a job, the worker would set the current 
status to the status representing the outcome of the processing, complete, error, need 
graphs, etc., and the update flag to on. The supervisor 308 when polling the job status 
table would examine those job records having an update flag "on" and determine 
whether the current worker and current status in the job record matches the"From 
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Worker" and "From State" in one worker transition table record. If there is a match, 
then the supervisor 308 sets the current status to the "To State" and current worker to 
the "To Worker" in the matching worker transition record. The update flag would be 
left "on." The supervisor 308 would then invoke the "To Worker" to cause the "To 
5 Worker" to process the job table and recently updated record. The invoked worker, 
upon locating a record with the update flag "on" and having a Current Worker and 
Current status matching its input status, would turn the update flag "off' and then 
process the job. 

For instance, if the Condition worker completed a job, it would update the 

1 0 current status in the job status table to complete and set the update flag to "on". Upon 
polling the job status table, the supervisor 308, would process the record having its 
update flag "on", and notice that the current status of Condition and current state of 
complete for the job record matches the "From Worker" and "From State" in one 
transition record. The supervisor 308 would then update the current worker and 

15 current status in the job record to the "To Worker" and "To State" in the matching 
workflow transition table record. Upon updating a record in the job status table, the 
supervisor 308 would invoke the new current worker to process the job status table. 

Moreover, the supervisor 304 might perform such additional operations as 
maintaining resources for workers to use (database connections, file handles, network 

20 connections, threads, etc.); load balancing among the workers (keep track of how 

many instances of a particular worker are running concurrently and route work among 
them, limit the number of concurrent workers based on system configuration, etc.); and 
monitoring job state changes to provide a common point of control for unexpected 
interruptions in the job flow. Moreover, the supervisor 304 may allow multiple 

25 workers to operate concurrently and share resources. Such workers would process 
different jobs in parallel. The supervisor 304 may manage the resource sharing 
among concurrently executing workers. The worker, in response to being invoked, 
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queries the job status table 310 for the jobs having the input status of the invoked 
worker. 

In response to being invoked, the invoked worker 312, 314, 318, 320, 322, 
324, 326 or 328 would obtain a connection or handle to the database 252 from the 
5 supervisor 308. Alternatively, the worker may maintain its own connection to the 
database 252. Connections with the database 252 may utilize any database 
connection protocol known in the art, such as an as Open Database Connectivity 
(ODBC) to access the records in the database. The supervisor 304 maintains a 
constant open cormection with the job status table 254 as the supervisor 304 is 

10 continuously polling the job status table for jobs to process. The worker 3 12, 314, 
318, 320, 322, 324, 326 or 328 then performs its worker specific operations on the 
job. In processing the job, the worker may process the worker specific tables 258 
which include configuration information for each worker depending on the attributes 
of a job. After completing the operations, the worker 312, 314, 318, 320, 322, 324, 

1 5 326 or 328 sets the status for the job in the job status table 254 to one output status 
which will be used to cause the supervisor 304 to invoke the next worker in the 
workflow to access and process the job. 

The job status table 304, supervisor 308 and workers 312, 314, 318, 320, 322, 
324, 326 or 328 may be implemented on the same or separate machines. If the 

20 components are on separate machines or distributed among multiple server nodes, 
then the components would communicate over a network interconnecting the nodes. 

When a worker is finished processing the job, then the supervisor 308, the 
worker or some other process would process the workflow transition table 256 to 
determine the appropriate output status to set for the job status. If the processing of 

25 the job failed, the worker may set the status to an error status to cause the supervisor 
3 10 to invoke an error worker 380. Otherwise, the worker would set the job status to 
complete. In this way, the workflow path or order of job processing is defined by 
altering the current status field in the job status table to cause the supervisor 308 to 
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change the current status and current worker to the next worker in the workflow based 
upon the workflow transition table 256. 

Below are an example of the different workers that may be included in a 
production system. 

5 The data conditioning worker 312 performs certain data cleaning and checking 

operations on the data in the customer record created at the input center 4. The data 
conditioning worker 312 may check each field in the customer record to determine if 
the entered data is valid, e.g., falls within a vaUd range. Alternatively, the data 
conditioning worker 312 could set the value in a field based on the value in another 

1 0 field. For instance, if the value in an age field is within one range, then the data 
conditioning worker 3 12 would set the set the status of the job to the input status of 
the page construction worker 3 14 to continue the job processing. Otherwise, if the 
value is within another range, then the data conditioning worker could set the status to 
"complete" to end the job. There may be a worker specific table 258 for the data 

15 conditioning worker that would indicate certain formatting to use for different fields 
in the customer record. In this way, the data conditioning worker 312 processes the 
customer data record to ensure that the data is valid and ready for the next operation. 

The page construction worker 3 14 performs the operations at blocks 200 to 
208 in FIGs. 5a and 5b to fill in the template with data to generate a docxmient in a 

20 page definition language such as PostScript. 

After the document is generated, the imposition worker 318 may reformat how 
the document is specified to print given the page dimensions and dimensions of the 
paper on which the document will be printed. For instance, if the document pages are 
8.5x11 inches and the printer paper is a roll of paper 1 8 inches wide, then the 

25 imposition worker 3 1 8 could reformat the Postscript file outputted fi:om the page 
construction worker 3 14 to print two pages side-by-side. Further, if the document is 
specified to be printed as a pamphlet, then the imposition worker 318 may reset the 
formatting to print the first and last page, second and second to last page, etc., on the 
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same page to form pamphlet pages. To determine the settings to use, the imposition 
worker 318 may access a worker specific table 258 for the imposition worker that 
includes printing settings for different types of print jobs. For instance, there may be 
a record in the imposition worker specific table for pamphlet configuration 
5 parameters, a record for configuration settings for certain printers, etc. The 

imposition worker 318 may select a record in the worker specific table 258 based on 
field values in the customer record. In this way, the imposition worker 3 1 8 obtains 
parameters fi'om the imposition worker specific table 258 to use to set print format 
values based on the value in certain fields of the customer record being processed. 

10 The table of contents worker 320 generates a table of contents for the output 

document generated by the page construction worker 314 if the page construction 
worker 314 does not include the capabihty to generate the table of contents. In 
preferred embodiments, the table of contents may be predefined and maintained in a 
table of contents worker specific table 258. In such case, the table of contents worker 

15 320 would determine the table of contents from the worker specific table 258 

according to a value in the customer record indicating the document to produce. The 
table of contents specific table 258 would include records of table of contents to use 
for different documents. The table of contents worker 320 may scan the output 
docimient for certain section indicators and headers to determine the page numbers 

20 for the different sections listed in the table of contents. The table of contents worker 
320 would insert the generated table of contents into the output document. 

The graph worker 322 may generate graphs for the generated document if the 
page construction worker 3 14 does not include such a capability. The page 
construction worker 3 14 would then insert the generated graphs into the document 

25 being generated. 

The output manager worker 324 would convert the generated output to a 
printer readable format, i.e., rasterize or transform the image into a bit map file. The 
output manager worker 324 would perform the steps at blocks 228-234 in FIG. 5b to 
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rasterize the generated output file in a page description format such as PostScript and 
then convert to a format suitable for the output device 14, 16 or 18 specified in the 
customer record. The output manager worker 324 may access an output manager 
worker specific table 258 including delivery parameters to use depending on the 
5 selected delivery method. Thus, there would be a record in the output delivery 
worker specific table 258 for each type of delivery method including parameters to 
use when generating output for a particular output delivery method. The output 
manager worker 324 may comprise the InfoPrint Manager software for processing 
print files and routing to an output device, 

1 0 The error worker 326 would process jobs having error status and perform error 

recovery operations. The error worker 327 may redrive a job by setting the output 
status to the input status of the first worker in the workflow or at any other worker in 
the workflow process. 

The accounting worker 328 performs various accounting and billing 

15 operations after a print job is routed to the output device, i.e., has the delivered status. 
The accounting worker 328 could determine a cost for the print job based on the 
number of pages printed and the value of any items shipped with the printed output 
and then automatically generate an invoice to print and deliver to the customer via fax 
16, e-mail 18, or postal mail. 

20 A clean-up worker (not shown) may be used to delete jobs that have remained 

in the job status table 254 for a predetermined period of time or that have a completed 
status. This clean-up worker deletes all job-related files and information and the 
database records for the job, 

FIG. 6 finther shows an example of possible input status values ready, build, 

25 impose, table of contents, graph, output, error, and delivered associated with the 

workers 312, 314, 318, 320, 324, 326, and 328 respectively. FIG.9 illustrates outputs 
for the workers 312, 3 14, 318, 320, 324, 326, and 328. All workers have as a possible 
output the error worker 326, i.e., the error status, and likewise the error worker 326 
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has as possible outputs every other worker. The arrows indicate possible output 
values for each worker, thereby providing a workflow. Workers 312 and 3 1 8 have 
more than one non-error output statuses. For instance the data conditioning worker 
312, after successfully completing data conditioning operations, would set the status 
for the job to either graph or build. Thus, the data conditioning worker 3 1 2 would 
have to determine whether the job included graphs to build to determine the next 
possible status. Likewise, the imposition worker 318 would determine whether the 
job included a table of contents to determine whether to set the status to table contents 
or output. The accounting worker 328 has a non-error output status of completion to 
indicate the total completion of the job. The complete status is the input status to a 
clean worker which removes entries from the job status table 254 as discussed above. 

In further embodiments, there may be multiple workers in the workflow 
process system for different classes of workers. An example of different classes of 
workers includes: 

data input worker class: reads data from customer sources by accessing 
customer data records entered at the data input computer 4, reading an input 
database, watching for files to arrive in a specific directory, and so on). 
data conditioning worker class : performs statistical characterization of data, 
removes records with spurious data, limits data to a valid range, manipulates 
existing data to produce new fields that workers might need, etc. 
formatting data worker class : generates text, image processing, generating graphs, 
charts and tables, etc. 

composing data worker class : lays out formatted objects on pages, generates 
tables of contents, indexes, flowing text, etc, 

processing composed pages worker class : imposes pages on sheets, encrypting 
the data stream, watermarks the data stream, sorts the data stream for 
efficient mailing, etc. 

output management worker class : sends processed pages to ou^ut devices and 
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manages the print, fax, email, etc. procedure. 

post-processing management worker class : tracks and controls finishing equipment 
like folders, trimmers, drills, binders, as well as inserters and mailing 
procedures. 

follow up worker-class : handles notification of success or failure, handles 
errors for tracking and reporting 

accounting worker class : interfaces with foreign systems for accounting, 
billing, inventory control, etc. 

The workflow management process is illustrated in FIGs. 9 and 10 and 
utilizing a job status table and workflow transition table as described with respect to 
FIGs, 7 and 8, Control begins at block 400 in FIG. 9 with the supervisor 304 polling 
the jobs status table 308 at predetermined intervals. The supervisor 304 begins a loop 
at block 402 and accesses each job record in the job entry table having the update flag 
on. For each job, the supervisor 304 determines (at block 404) whether the current 
worker and current status in the job record matches the "From Worker" and the "From 
State" in one record in the workflow transition table 256 for the workflow indicated in 
the workflow name field. If the supervisor 308 locates a matching record in the 
workflow transition table, then the supervisor 308 sets (at block 406) the current 
worker and current status in the job record being considered to the "From Worker" 
and "From State" in the located workflow transition record, and sets (at block 408) the 
update flag to "on". Setting the update flag "on" will trigger the worker to consider 
the record when querying the job status table 254. The supervisor 308 invokes (at 
block 410) the new current worker to process the job status table 254 and 
then proceeds (at block 412) to consider the next entry in the job status table having 
the update flag "on". In further embodiments, the supervisor 308 and worker may 
process records in the job status table 254 according to a priority ordering specified 
for each record in the job status table. 
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FIG. 1 1 illustrates the steps performed by the workers 3 12-328 upon being 
invoked by the supervisor 304. If the worker being invoked is already processing the 
job status table 254, then the worker may ignore the invocation. At block 450^ the 
invoked worker queries the job status table 254. The worker may query the job status 
5 table according to a priority ordering of the jobs in the job status table 254. The 
worker then begins a loop at block 452 to process each job having the update flag 
"on", and the current worker and current status equal to the invoked worker and ready 
status. The worker sets (at block 454) the update status to "off for the record during 
the time the worker is processing the job. The worker performs (at block 454) the 

10 worker specific operations, e.g., data conditioning, generating a graph, constructing a 
page, imposition reformatting, generating a table of contents, generating and 
delivering ou^ut, accounting, etc. After completing job processing, the worker 
would then update (at block 458) the current state in the job record to the outcome of 
processing the job, e.g., complete or error and set the update flag to "on" to cause the 

1 5 supervisor 308 to consider the job record. Alternatively, the worker may send a 
message to the supervisor 304 indicating the outcome of the job processing, e.g., 
success, error, etc. The worker would proceed (at block 460) back to block 452 to 
consider more jobs having the worker status in the job status table 254. 

In this way, the job status table 254 and workflow transition table 256 are used 

20 to provide a database driven workflow management system to produce output, such as 
printed or otherwise distributed customer materials. 

In preferred embodiments, the database 252 includes the job status history 
table 262 that has a field for the job id, the status, and a time stamp when the status 
was set. Every time the supervisor 304 updates the status for the job, the supervisor 

25 304 would also add the new status to the job status history table 262. This history 
table 262 may be used for tracking purposes to allow a tracking program to determine 
where a job has been and its current position in the workflow process. 
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The preferred workflow management embodiment provides a method, system, 
and program to automatically route a job through the workflow system in an order 
defined by input and output status settings for the workers. In this way, a print job is 
automatically routed through the system by a series of worker processes without the 
5 need for human intervention, except when manual operations must be performed, e.g., 
inserting documents into an envelop, cutting, etc. Even when manual operations are 
involved, the automated workers may monitor the status of manual operations. When 
the workflow is implemented in a distributed computing environment, then the job 
status table could contain information on the job utilized by the workflow threads to 
1 0 identify the location of the job in the workflow environment. 



This concludes the description of the preferred embodiments of the invention. 
The following describes some alternative embodiments for accomplishing the present 
15 invention. 

The preferred embodiments may be implemented as a method, apparatus or 
article of manufacture using standard programming and/or engineering techniques to 
produce software, firmware, hardware, or any combination thereof The term "article 
of manufacture" (or alternatively, "computer program producf ) as used herein is 

20 intended to encompass one or more computer programs and data files accessible from 
one or more computer-readable devices, carriers, or media, such as a magnetic storage 
media, "floppy disk," CD-ROM, a file server providing access to the programs via a 
network transmission line, holographic unit, etc. Of course, those skilled in the art 
will recognize that many modifications may be made to this configuration without 

25 departing from the scope of the present invention. 

Preferred embodiments were described with respect to a network system. 
However, in alternative embodiments, the software and system may be implemented 
in a single stand alone printer, including the functions performed by the data input 
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computer and printer manager^ database program, an e-mail and fax connection, and 
an attached printer. This would allow a smaller business to utilize the preferred 
embodiments to design and execute a direct mail campaign to distribute marketing 
materials. Alternatively, certain of the functions shown as distributed in FIG, 1 may 
5 be combined in any manner into one or more systems. For instance, a single 
computer may include the functions of the output constructor 10 and data input 
computer 4, 

Preferred embodiments described the job status table, workflow transition 
table, customer information, metadata describing the files, and other tables as 

10 implemented as database records in a database table. However, any of the 

information described as being implemented as a database table may be implemented 
in any format for maintaining object information, including spreadsheet, non-database 
table, etc. Thus, as used herein, the terms database record, database table, metadata, 
and database refer to any data structure known in the art for maintaining information 

15 on data objects, such as relational databases, non-relational databases, spreadsheets, 
ASCII text files, etc. 

In further embodiments, there may be numerous data input computers 4 where 
many operators gather customer information to continually update the customer 
records in the customer database. 

20 Preferred embodiments were described with respect to corporate users of 

printer products. However, in further embodiments the customer may comprise 
individuals as well as businesses. Moreover, the product information represented in 
the customer records may be for any possible product. In this way, preferred 
embodiments may be used to target a direct mail or e-mail campaign to numerous 

25 individuals. Thus, the term "customer" as used herein refers to any intended recipient 
of output generated in accordance with preferred embodiments. 

Preferred embodiments were described with respect to generating marketing 
materials. However, in further embodiments, the system of the preferred 




30 Express Mail No. EL414495506US 

Docket No. BO9-99-028 
Firm No. 0036.0043 

embodiments may be used to generate material for distribution for non-commercial 
purpose. For instance, a non-profit organization or election campaign could utilize 
information to generate materials to distribute to individuals to develop interest in 
their cause. Alternatively, a corporation or any other person, could use the preferred 
5 embodiments to deliver tailored information to a group of people, such as employees, 
friends, etc. 

Preferred embodiments were described with respect to invoking workers. The 
step of invoking a worker may comprise invoking a worker subroutine or sending a 
message to an active worker. 

1 0 Preferred embodiments provided and example of workers used to create and 

deliver marketing materials. In alternative embodiments, functions described with 
respect to one worker may be divided into multiple different workers. Further, 
additional workers may be added to perform further document processing operations. 
For instance, workers may be used to monitor any pre or post processing equipment 

15 involving machine or human controlled processing, such as inserting, trimming, 
unwinding or any other finishing operation. 

Preferred embodiments were described with respect to specific information 
types in the customer records describing customer preferences with respect to a 
printing system. However, in further embodiments when different products or 

20 customers are involved, the customer record may include any number of fields 
describing any type of customer preference, desire, goal, current products that are 
used, etc., that could be helpful in creating and selecting content to include in 
customized marketing materials. 

In summary, preferred embodiments disclose a workflow management system 

25 for creating and delivering output material. A customer record is generated to include 
fields specifying at least one product, customer preferences, and a selected output 
method to deliver generated output material on the product specified in the customer 
record. A job record including a status field is added to a job status table for the 
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customer record. The added job record status is set to a first status. A selected job is 
processed in the job status table. A first worker is invoked if the selected job has the 
first status. The first worker generates output material fi:om processing the product 
and customer preference fields in the customer record for the selected job. The status 
5 for the selected job in the job status table is set to a second status after generating the 
output material. A second worker is invoked if the selected job has the second status. 
The second worker determines a selected one of a plurahty of delivery options from 
the customer record for the selected job and transmits the output material via the 
determined delivery option to the customer specified in the customer record. 

1 0 The foregoing description of the preferred embodiments of the invention has 

been presented for the purposes of illustration and description. It is not intended to be 
exhaustive or to limit the invention to the precise form disclosed. Many 
modifications and variations are possible in light of the above teaching. It is intended 
that the scope of the invention be limited not by this detailed description, but rather by 

15 the claims appended hereto. The above specification, examples and data provide a 
complete description of the manufacture and use of the composition of the invention. 
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Since many embodiments of the invention can be made without departing from the 
spirit and scope of the invention, the invention resides in the claims hereinafter 



=^*AIX, OS/2, and RS/6000 are registered trademarks of IBM and OS/390 and MVS 
are trademarks of IBM; WINDOWS is a registered trademark of Microsoft 
Corporation; UNIX is a registered trademark licensed by the X/Open Company LTD; 
ADOBE ACROBAT is a registered trademark of Adobe System, Inc.; PAGEFLEX is 
10 a trademark of Bitstream, Inc. 



appended. 
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WHAT IS CLAIMED IS: 



1 LA workflow management system for creating and delivering output 

2 material, comprising: 

3 generating a customer record to include fields specifying at least one product, 

4 customer preferences, and a selected output method to deliver generated output 

5 material on the product specified in the customer record; 

6 adding a job record including a status field to a job status table for the 

7 customer record; 

8 setting the added job record status to a first status; 

9 processing a selected job in the job status table; 

10 invoking a first worker if the selected job has the first status; 

1 1 generating, with the first worker, output material from processing the product 

12 and customer preference fields in the customer record for the selected job; 

1 3 setting the status for the selected job in the job status table to a second status 

14 after generating the output material with the first worker; 

1 5 invoking a second worker if the selected job has the second status; 

1 6 determining, with the second worker, a selected one of a plurality of delivery 

17 options from the customer record for the selected job; and 

1 8 transmitting, with the second worker, the output material via the determined 

1 9 delivery option to the customer specified in the customer record. 

1 2 . The method of claim 1 , wherein the first worker generates output 

2 material by: 

3 accessing at least one content file by processing a database table using values 

4 in the customer record associated with the selected job; and 

5 generating the content of each accessed file into the output material. 
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1 3 . The method of claim 2, wherein the first worker further performs: 

2 processing a template including queries of records in the database table; 

3 accessing at least one value in a field in one customer record to include in a 

4 query against the database table; and 

5 applying the query against the second database to determine a record 

6 associated with a file including fields matching the query, wherein the accessed file is 

7 associated with the determined record, and wherein generating the content into the 

8 output material comprises generating the content from the accessed file into the 

9 template, which forms the output material 



1 4. The method of claim 1 , wherein the first status is associated with the 

2 first worker and the second status is associated with the second worker, wherein the 

3 first and second workers fiirther perform querying the job status table to access all 

4 jobs having the status associated with the worker. 

1 5 . The method of claim 1 , further comprising: 

2 determining, with the first and second workers, whether an error occurred 

3 while processing the selected job; 

4 setting, with the fu*st and second workers, the status in the job status table for 

5 the selected job to an error status; 

6 invoking an error worker if the selected job has the error status; 

7 performing, with the error worker, error recovery operations for the selected 

8 job; and 

9 setting, with the error worker, the status of the selected job to one of the first 
10 and second statuses after the error recovery operation. 

1 6, The method of claim 1 , wherein the job status table is processed by a 

2 supervisor program that polls the job status table at predetermined intervals, wherein 
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3 the supervisor program performs the steps of invoking the first and second workers, 

4 and wherein the supervisor program processes every record in the job status table 

5 when performing the polUng operation. 

1 7, The method of claim 1 , wherein a worker transition table includes a 

2 plurality of records, each indicating an input worker, a completion state, an output 

3 worker, and an output status, wherein the input worker indicates the worker assigned 

4 to process the job, the completion state is a status indicated for the job after the input 

5 worker processes the job, the output worker is the worker that processes the job after 

6 having been processed by the input worker and resulting in the completion state, and 

7 the output state is the state to which the job status in the job status table is set, and 

8 wherein the job status table fiirther indicates a current worker assigned to process the 

9 job, wherein setting the status for the selected job in the job status table comprises 

1 0 determining ft*om the worker transition table one record having an input worker and 

1 1 completion state matching the current worker and the job status, respectively, and 

12 setting the status for the selected job to the output state and the current worker to the 

13 output worker 

1 8. The method of claim 7, fiirther comprising invoking the output worker 

2 after setting the job status to the output status. 

1 9. The method of claim 7, wherein setting the status for the selected job 

2 after processing the job with one worker, comprises the worker completing processing 

3 the job setting the completion status to a state indicating an outcome of processing the 

4 job. 
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1 10. The method of claim 1, further comprising: 

2 setting the status to a third status after adding the job entry in the job status 

3 table; 

4 invoking a data conditioning worker if the job status for the selected job is the 

5 third status; 

6 processing, with the data conditioning worker, the customer record to 

7 determine whether at least one value satisfies at least one condition; 

8 taking corrective actions, with the data conditioning worker, if the data in the 

9 customer record does not satisfy each condition; and 

10 setting the status of the selected job to the first status if the data in the 

1 1 customer record satisfies each condition. 

1 11. The method of claim 6, further comprising an imposition worker and 

2 table of contents worker, wherein the supervisor sets the job status to an imposition 

3 status and table of content status, and wherein the supervisor invokes the imposition 

4 and table of content workers. 

1 12. The method of claim 1 , further comprising: 

2 generating information on the output material; 

3 setting the status for the selected job in the job status table to a third status; 

4 invoking an accounting worker if the job has the third status; 

5 processing, with the accounting worker, the generated information on the 

6 output material to determine costs of generating the output material; and 

7 generating, with the accounting worker, an invoice including the determined 

8 costs of the output material. 



1 

2 



13. The method of claim 1, wherein there are multiple workers each 
associated with one input status and at least one output status, wherein the status of 
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3 the job is updated to one associated output status after one worker completes 

4 processing a job, wherein the output status for one worker is the input status 

5 associated with one other worker, and wherein the definition of input and output 

6 statuses for workers defines the workflow of the job. 



1 14. A workflow management system for creating and delivering output 

2 material, comprising: 

3 means for generating a customer record to include fields specifying at least 

4 one product, customer preferences, and a selected output method to deliver generated 

5 output material on the product specified in the customer record; 

6 means for adding a job record including a status field to a job status table for 

7 the customer record; 

8 means for setting the added job record status to a first status; 

9 means for processing a selected job in the job status table; 

1 0 means for invoking a first worker if the selected job has the first status; 

1 1 means for generating, with the first worker, output material from processing 

12 the product and customer preference fields in the customer record for the selected job; 

13 means for setting the status for the selected job in the job status table to a 

14 second status after generating the output material with the first worker; 

1 5 means for invoking a second worker if the selected job has the second status; , 

16 means for determining, with the second worker, a selected one of a plurality of 

17 delivery options from the customer record for the selected job; and 

1 8 means for transmitting, with the second worker, the output material via the 

19 determined delivery option to the customer specified in the customer record. 

1 15. The system of claim 14, wherein the means, performed by the first 

2 worker, for generating output material comprises: 
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3 accessing at least one content file by processing a database table using values 

4 in the customer record associated with the selected job; and 

5 generating the content of each accessed file into the output material. 

1 1 6. The system of claim 1 5, wherein the first worker fiirther comprises: 

2 means for processing a template including queries of records in the database 

3 table; 

4 means for accessing at least one value in a field in one customer record to 

5 include in a query against the database table; and 

6 means for applying the query against the second database to determine a 

7 record associated with a file including fields matching the query, wherein the 

8 accessed file is associated with the determined record, and wherein generating the 

9 content into the output material comprises generating the content fi-om the accessed 
1 0 file into the template, which forms the output material. 

1 17. The system of claim 14, wherein the first status is associated with the 

2 first worker and liie second status is associated with the second worker, wherein the 

3 first and second workers fiirther comprises means for querying the job status table to 

4 access all jobs having the status associated with the worker. 

1 18. The system of claim 14, fiirther comprising: 

2 means for determining, with the first and second workers, whether an error 

3 occurred while processing the selected job; 

4 means for setting, with the first and second workers, the status in the job status 

5 table for the selected job to an error status; 

6 means for invoking an error worker if the selected job has the error status; 

7 means for performing, with the error worker, error recovery operations for the 

8 selected job; and 
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9 means for setting, with the error worker, the status of the selected job to one of 
10 the first and second statuses after the error recovery operation. 

1 19. The system of claim 14, wherein the job status table is processed by a 

2 supervisor program that polls the job status table at predetermined intervals, wherein 

3 the supervisor program includes the means for invoking the first and second workers, 

4 and wherein the supervisor program fiirther comprises means for processing every 

5 record in the job status table when performing the polling operation. 

1 20. The system of claim 1 4, wherein a worker transition table includes a 

2 plurality of records, each indicating an input worker, a completion state, an output 

3 worker, and an output status, wherein the input worker indicates the worker assigned 

4 to process the job, the completion state is a status indicated for the job after the input 

5 worker processes the job, the output worker is the worker that processes the job after 

6 having been processed by the input worker and resulting in the completion state, and 

7 the output state is the state to which the job status in the job status table is set, and 

8 wherein the job status table fiirther indicates a current worker assigned to process the 

9 job, wherein the means for setting the status for the selected job in the job status table 

1 0 comprises determining fi-om the worker transition table one record having an input 

1 1 worker and completion state matching the current worker and the job status, 

12 respectively, and setting the status for the selected job to the output state and the 

13 current worker to the output worker 



1 21. The system of claim 20, fiirther comprising means for invoking the 

2 output worker after setting the job status to the output status. 

1 22. The system of claim 20, wherein the means for setting the status for 

2 the selected job after processing the job with one worker, comprises the worker 
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3 completing processing the job setting the completion status to a state indicating an 

4 outcome of processing the j ob. 

1 23. The system of claim 14, further comprising: 

2 means for setting the status to a third status after adding the job entry in the 

3 job status table; 

4 means for invoking a data conditioning worker if the job status for the selected 

5 job is the third status; 

6 means for processing, with the data conditioning worker, the customer record 

7 to determine whether at least one value satisfies at least one condition; 

8 means for taking corrective actions, with the data conditioning worker, if the 

9 data in the customer record does not satisfy each condition; and 

1 0 means for setting the status of the selected job to the first status if the data in 

1 1 the customer record satisfies each condition. 

1 24. The system of claim 1 9, fixrther comprising an imposition worker and 

2 table of contents worker, wherein the supervisor includes: 

3 means for setting the job status to an imposition status and table of content 

4 status; and 

5 means for invoking the imposition and table of content workers. 

1 25. The system of claim 14, further comprising: 

2 means for generating information on the output material; 

3 means for setting the status for the selected job in the job status table to a third 

4 status; 

5 means for invoking an accounting worker if the job has the third status; 

6 means for processing, with the accounting worker, the generated information 

7 on the output material to determine costs of generating the output material; and 
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9 



8 



means for generating, with the accounting worker, an invoice including the 
determined costs of the output material. 



1 



26, The system of claim 14, wherein there are multiple workers each 



2 associated with one input status and at least one output status, wherein the status of 

3 the job is updated to one associated output status after one worker completes 

4 processing a job, wherein the output status for one worker is the input status 

5 associated with one other worker, and wherein the definition of input and output 

6 statuses for workers defines the workflow of the job. 

1 27. An article of manufacture for use in a workflow management system 

2 for creating and dehvering output material, the article of manufacture comprising 

3 computer readable storage media including a plurality of computer programs, 

4 including a first worker and second worker, embedded therein capable of causing at 

5 least one computer to perform: 

1 generating a customer record to include fields specifying at least one product, 

2 customer preferences, and a selected output method to deliver generated ou^ut 

3 material on the product specified in the customer record; 

4 adding a job record including a status field to a job status table for the 

5 customer record; 

6 setting the added job record status to a first status; 

7 processing a selected job in the job status table; 

8 invoking the first worker if the selected job has the first status; 

9 generating, with the first worker, output material from processing the product 

10 and customer preference fields in the customer record for the selected job; 

1 1 setting the status for the selected job in the job status table to a second status 

12 after generating the output material with the first worker; 

13 invoking the second worker if the selected job has the second status; 
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14 determining J with the second worker, a selected one of a plurality of delivery 

15 options from the customer record for the selected job; and 

16 transmitting, with the second worker, the output material via the determined 

1 7 delivery option to the customer specified in the customer record, 

1 28. The article of manufacture of claim 27, wherein the first worker 

2 generates output material by: 

3 accessing at least one content file by processing a database table using values 

4 in the customer record associated with the selected job; and 

5 generating the content of each accessed file into the output material. 

1 29. The article of manufacture of claim 27, wherein the first worker fiirther 

2 causes the at least one computer to perform: 

3 processing a template including queries of records in the database table; 

4 accessing at least one value in a field in one customer record to include in a 

5 query against the database table; and 

6 applying the query against the second database to determine a record 



7 associated with a file including fields matching the query, wherein the accessed file is 

8 associated with the determined record, and wherein generating the content into the 

9 output material comprises generating the content from the accessed file into the 
1 0 template, which forms the output material. 

1 30. The article of manufacture of claim 27, wherein the first status is 

2 associated with the first worker and the second status is associated with the second 

3 worker, wherein the first and second workers further cause the at least one computer 

4 to perform querying the job status table to access all jobs having the status associated 

5 with the worker. 
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1 31. The article of manufacture of claim 27, wherein the computer 

2 programs embedded in the computer useable media further includes an error worker, 

3 further comprising: 

4 determining, with the first and second workers, whether an error occurred 

5 while processing the selected job; 

6 setting, with the first and second workers, the status in the job status table for 

7 the selected job to an error status; 

8 invoking the error worker if the selected job has the error status; 

9 performing, with the error worker, error recovery operations for the selected 

10 job; and 

1 1 setting, with the error worker, the status of the selected job to one of the first 

1 2 and second statuses after the error recovery operation. 

1 32. The article of manufacture of claim 27, wherein the computer 



2 programs embedded in the computer useable media further include a supervisor 

3 program, wherein the job status table is processed by the supervisor program that 

4 polls the job status table at predetermined intervals, wherein the supervisor program 

5 causes the at least one computer to perform invoking the first and second workers, 

6 and wherein the supervisor program processes every record in the job status table 

7 when performing the polling operation. 

1 33. The article of manufacture of claim 27, wherein a worker transition 

2 table includes a plurality of records, each indicating an input worker, a completion 

3 state, an output worker, and an output status, wherein the input worker indicates the 

4 worker assigned to process the job, the completion state is a status indicated for the 

5 job after the input worker processes the job, the output worker is the worker that 

6 processes the job after having been processed by the input worker and resulting in the 

7 completion state, and the output state is the state to which the job status in the job 
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8 status table is set, and wherein the job status table further indicates a current worker 

9 assigned to process the job, wherein setting the status for the selected job in the job 

1 0 status table comprises determining from the worker transition table one record having 

1 1 an input worker and completion state matching the current worker and the job status, 

12 respectively, and setting the status for the selected job to the output state and the 

1 3 current worker to the output worker. 

1 34. The article of manufacture of claim 3 3 , further comprising invoking 

2 the output worker after setting the job status to the output status. 

1 35. The article of manufacture of claim 33, wherein setting the status for 

2 the selected job after processing the job with one worker comprises the worker 

3 completing processing the job setting the completion status to a state indicating an 

4 outcome of processing the job. 

1 36. The article of manufacture of claim 27, wherein the computer 

2 programs embedded in the computer useable media fiirther includes a data 

3 conditioning worker, fiirther comprising: 

4 setting the status to a third status after adding the job entry in the job status 



5 



table; 



6 



invoking a data conditioning worker if the job status for the selected job is the 



7 



third status; 



8 



processing, with the data conditioning worker, the customer record to 



10 



9 



determine whether at least one value satisfies at least one condition; 

taking corrective actions, with the data conditioning worker, if the data in the 



11 



12 



customer record does not satisfy each condition; and 

setting the status of the selected job to the first status if the data in the 



13 



customer record satisfies each condition. 
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1 37. The article of manufacture of claim 32, wherein the computer 

2 programs embedded in the computer useable media further include an imposition 

3 worker and table of contents worker, wherein the supervisor sets the job status to an 

4 imposition status and table of content status, and wherein the supervisor invokes the 

5 imposition and table of content workers. 

1 38. The article of manufacture of claim 27, further comprising: 

2 generating information on the output material; 

3 setting the status for the selected job in the job status table to a third status; 

4 invoking an accounting worker if the job has the third status; 

5 processing, with the accounting worker, the generated information on the 

6 output material to determine costs of generating the output material; and 

7 generating, with the accounting worker, an invoice including the determined 

8 costs of the output material. 

1 39. The article of manufacture of claim 27, wherein there are multiple 

2 workers each associated with one input status and at least one output status, wherein 

3 the status of the job is updated to one associated ou^ut status after one worker 

4 completes processing a job, wherein the output status for one worker is the input 

5 status associated with one other worker, and wherein the definition of input and 

6 output statuses for workers defines the workflow of the job. 
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A DATABASE DRIVEN WORKFLOW MANAGEMENT SYSTEM FOR 
GENERATING OUTPUT MATERIAL BASED ON CUSTOMER INPUT 

ABSTRACT 

Disclosed is a workflow management system for creating and delivering 
5 output material. A customer record is generated to include fields specifying at least 
one product, customer preferences, and a selected output method to deliver generated 
output material on the product specified in the customer record. A job record 
including a status field is added to a job status table for the customer record. The 
added job record status is set to a furst status. A selected job is processed in the job 
10 status table. A fu-st worker is invoked if the selected job has the first status. The first 
worker generates output material fi-om processing the product and customer 
preference fields in the customer record for the selected job. The status for the 
selected job in the job status table is set to a second status after generating the output 
material. A second worker is invoked iftheselectedjob has the second status. The 
1 5 second worker determines a selected one of a plurality of delivery options fi-om the 
customer record for the selected job and transmits the output material via the 
determined delivery option to the customer specified in the customer record. 
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Highlights 



Features high throughput at up 
to 30 ipm, and up to 200,000 
impressions per month 

Supports multiple data streams 
including PostScript Level 2, 
PCLSe and IPDS 

Handles seven paper sizes 
including A3/ledger (11 "x17") 
^paper 

Connects to three network 
interfaces simultaneously 

Offers duplex model for f ivo- 
sided printing 

Separates print jobs with 
dedicated input trays and 
output stackers 

Supports up to four input trays 
66 that hold 3,000 sheets of paper 

\ f Low cost of operation 

r Increase print performance, 
\ error recovery and attachment 
\jlexibility with the AFCCU 




\ 



The highly reliable, cut-sheet IBIVI® 3130 
Advanced Function Printer combines 
quality printing and media flexibility with 
multipie-interface networking. The printer's 
advanced controller technology simplifies 
the printing operations of complex com- 
puting environments. 

Environment sharing 

Today's complex computing environments 
require a printer to support multiple data 
streams and network connections. The 
IBM 3130 natively supports PostScript® 
Levei 2, PCL5e, and IPDS^"^ data streams, 
as well as data stream sensing and 
switching. With these capabilities, the IBM 
3130 can print from both host and Local 
Area Network (LAN) connections with effi- 
ciency The printer can also support three 
network interfaces simultaneously Open 
system attachments include Token-Ring, 
Ethernet and PC Parallel interfaces. 
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Media flexibility 

in addition to card stock and labels, the 
IBM 3130 handles ail popular paper types 
and seven paper sizes, including 
A3/ledger (11"x17") paper. With an input 
capacity of up to 3,000 sheets, an output 
capacity of up to 2,500 sheets, and a print 
speed of 30 ipm, the IBM 3130 easily 
handles large-volume print jobs. To retain 
print job separation, each input tray and 
output stacker can be linked and dedi- 
cated to a specified application. 

Advanced controller performance 

The IBM 3130 leverages the power of the 
Advanced Function Common Control 
Uni™ (AFCCU™) to ensure quality perfor- 
mance, reliability and efficiency The 
control unit's RISC technology incorpo- 
rates attachment flexibility so the printer 
can support Intelligent Printer Data 
Stream™ (IPDS) environments as well as 
LAN environments. The AFCCU supports 
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Connections 

-SNA Token-Ring 
-TCP/IP Token-Ring 
-TCP/IP Ethernet 
-PC Parallel 
-Twinax 
-SNASDLC 



The IBM 3130 Advanced Function Printer features high-throughput, the AFCCU and 
AFP software to cost-effectively produce large print Jobs over complex networks. 
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